goto fail;
op_default = op_bytes = (ar & (_SEGMENT_L|_SEGMENT_DB)) ? 4 : 2;
ad_default = ad_bytes = (ar & _SEGMENT_L) ? 8 : op_default;
- if ( !(ar & (_SEGMENT_CODE|_SEGMENT_S|_SEGMENT_P)) )
+ if ( !(ar & _SEGMENT_S) ||
+ !(ar & _SEGMENT_P) ||
+ !(ar & _SEGMENT_CODE) )
goto fail;
/* emulating only opcodes not allowing SS to be default */
&data_base, &data_limit, &ar,
_SEGMENT_WR|_SEGMENT_S|_SEGMENT_DPL|_SEGMENT_P) )
goto fail;
- if ( !(ar & (_SEGMENT_S|_SEGMENT_P)) ||
+ if ( !(ar & _SEGMENT_S) ||
+ !(ar & _SEGMENT_P) ||
(opcode & 2 ?
(ar & _SEGMENT_CODE) && !(ar & _SEGMENT_WR) :
(ar & _SEGMENT_CODE) || !(ar & _SEGMENT_WR)) )
movq %rsp,%rdi
movl $0xDEADBEEF,%eax
rep stosq
- popq %r9 ; popq %r8 ; popq %rcx; popq %rdx; popq %rsi; popq %rdi
+ popq %r8 ; popq %r9 ; xchgl %r8d,%r9d /* Args 5&6: zero extend */
+ popq %rdx; popq %rcx; xchgl %edx,%ecx /* Args 3&4: zero extend */
+ popq %rdi; popq %rsi; xchgl %edi,%esi /* Args 1&2: zero extend */
movl UREGS_rax(%rsp),%eax
pushq %rax
pushq UREGS_rip+8(%rsp)